<!--
// Copyright © 2022 Hardcore Engineering Inc.
//
// Licensed under the Eclipse Public License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License. You may
// obtain a copy of the License at https://www.eclipse.org/legal/epl-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
//
// See the License for the specific language governing permissions and
// limitations under the License.
-->
<script lang="ts">
  import contact, { Employee } from '@hcengineering/contact'
  import { Class, Doc, Ref } from '@hcengineering/core'
  import { Component } from '@hcengineering/tracker'
  import { getClient } from '@hcengineering/presentation'
  import { UsersPopup } from '@hcengineering/contact-resources'
  import { AttributeModel } from '@hcengineering/view'
  import { eventToHTMLElement, IconSize, showPopup } from '@hcengineering/ui'
  import { getObjectPresenter } from '@hcengineering/view-resources'
  import { IntlString } from '@hcengineering/platform'
  import tracker from '../../plugin'
  import LeadPopup from './LeadPopup.svelte'

  export let value: Employee | null
  export let object: Component
  export let size: IconSize = 'x-small'
  export let defaultClass: Ref<Class<Doc>> | undefined = undefined
  export let isEditable: boolean = true
  export let shouldShowLabel: boolean = false
  export let defaultName: IntlString | undefined = undefined

  const client = getClient()

  let presenter: AttributeModel | undefined

  $: if (value || defaultClass) {
    if (value) {
      getObjectPresenter(client, value._class, { key: '' }).then((p) => {
        presenter = p
      })
    } else if (defaultClass) {
      getObjectPresenter(client, defaultClass, { key: '' }).then((p) => {
        presenter = p
      })
    }
  }

  const handleLeadChanged = async (result: Employee | null | undefined) => {
    if (!isEditable || result === undefined) {
      return
    }

    const newLead = result === null ? null : result._id
    await client.update(object, { lead: newLead })
  }

  const handleLeadEditorOpened = async (event: MouseEvent) => {
    if (!isEditable) {
      return
    }
    showPopup(
      UsersPopup,
      {
        _class: contact.mixin.Employee,
        selected: value?._id,
        docQuery: {
          active: true
        },
        allowDeselect: true,
        placeholder: tracker.string.ComponentLeadSearchPlaceholder
      },
      eventToHTMLElement(event),
      handleLeadChanged
    )
  }
</script>

{#if value && presenter}
  <svelte:component
    this={presenter.presenter}
    {value}
    {defaultName}
    avatarSize={size}
    disabled={false}
    shouldShowPlaceholder={true}
    shouldShowName={shouldShowLabel}
    onEmployeeEdit={handleLeadEditorOpened}
    tooltipLabels={{ component: LeadPopup, props: { lead: value } }}
  />
{:else if presenter}
  <svelte:component
    this={presenter.presenter}
    {value}
    {defaultName}
    avatarSize={size}
    disabled={false}
    shouldShowPlaceholder={true}
    shouldShowName={shouldShowLabel}
    onEmployeeEdit={handleLeadEditorOpened}
    tooltipLabels={{ personLabel: tracker.string.AssignedTo, placeholderLabel: tracker.string.AssignTo }}
  />
{/if}
